热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

战舰|甲板_419.甲板上的战舰(阅读理解)

篇首语:本文由编程笔记#小编为大家整理,主要介绍了419.甲板上的战舰(阅读理解)相关的知识,希望对你有一定的参考价值。给你一个大小为mxn的矩阵board

篇首语:本文由编程笔记#小编为大家整理,主要介绍了419. 甲板上的战舰(阅读理解)相关的知识,希望对你有一定的参考价值。


给你一个大小为 m x n 的矩阵 board 表示甲板,其中,每个单元格可以是一艘战舰 'X' 或者是一个空位 '.' ,返回在甲板 board 上放置的 战舰 的数量。

战舰 只能水平或者垂直放置在 board 上。换句话说,战舰只能按 1 x k(1 行,k 列)或 k x 1(k 行,1 列)的形状建造,其中 k 可以是任意大小。两艘战舰之间至少有一个水平或垂直的空位分隔 (即没有相邻的战舰)。

示例 1:
输入:board = [["X",".",".","X"],[".",".",".","X"],[".",".",".","X"]]
输出:2
示例 2:

输入:board = [["."]]
输出:0

提示:

m == board.length
n == board[i].length
1 <&#61; m, n <&#61; 200
board[i][j] 是 &#39;.&#39; 或 &#39;X&#39;

进阶&#xff1a;你可以实现一次扫描算法&#xff0c;并只使用 O(1) 额外空间&#xff0c;并且不修改 board 的值来解决这个问题吗&#xff1f;

class Solution
public:
int countBattleships(vector>& board)
int ret&#61;0;
for(int i &#61; 0;i
for(int j &#61; 0;j
if(board[i][j]&#61;&#61;&#39;X&#39;)

if(i-1>&#61;0&&board[i-1][j]&#61;&#61;&#39;X&#39;||j-1>&#61;0&&board[i][j-1]&#61;&#61;&#39;X&#39;)

else
ret&#43;&#43;;



return ret;

;


推荐阅读
author-avatar
j相知相守相爱
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有